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= Saup to have thousands of ftp users ona single machine. In 
=| Control Panels addition to that I will show the use of quota and upload/download bandwidth limits with this setup. 
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=| PowerDNS This tutorial is based on Mandriva 2008 Spring (Mandriva 2008.1). You should already have set up a basic 
J djbdns Mandriva 2008 Spring system, for example as described in the first six chapters of this tutorial: 
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=| Programming might differ for you, so you have to replace them where appropriate. 
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=] Security This can all be installed with one single command: 

=] Anti-SpanvVirus ı urpmi MySQL MySQL-client phpmyadmin 
=| Storage Le nn eee eens 
=| Virtualization By default, networking is not enabled in Mandriva 2008 Spring's MySQL package. We can change this by 

l KVM commenting out the line skip-networkingin /etc/my.cnf: 
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on nee # (via the "enable-named-pipe" option) will render 
| Mini-Howtos it 
hone #Skip-networking 
Apache err! 
Backup 
DNS 
Errors | 
=) FIP El | Lr) 
MySQL Afterwards, we create the system startup links for MySQL and Apache... 
Networking a 
PHP ' chkconfig mysqld on 
Postfix ! chkconfig httpd on : 
Security .. and start both services: 
Sendmail RN A ATER OENE SEE ERATES EES IAT BOA EEANN TAE E AE A EEA EEEE AAE AAE AAA AAE ! 
Shell | /etc/init.d/mysqld start ! 
Other | /etc/init.d/httpd restart , 
ISPConfig . 
Create a password for the MySQL user root (replace yourrootsqlpasswordwith the password you want to 
Forums use): 
Contribute acs a RN Tals 
J ‘Cresta Content ! mysqladmin -u root password yourrootsqlpassword 
seals ere ' mysqladmin -h serverl.example.com -u root password yourrootsqlpassword 
Subscription ee = ney e crest rendre: peers creeper eee cP 
Login 
Site Map/RSS 3 Install PureFTPd With MySQL Support 
Feeds Mandriva's PureFTPd package supports various backends, such as MySQL, PostgreSQL, LDAP, etc. We install 
it like this: 
User login ı urpmi pure-ftpd pure-ftpd-anon-upload pure-ftpd-anonymous 
Username: ee ee 
| Then we create an ftp group (ftpgroup) and user (ftpuser) that all our virtual users will be mapped to. 
Password: Replace the group- and userid 2001 with a number that is free on your system: 
| Remember Me? ' groupadd -g 2001 ftpgroup ! 
: ' useradd -u 2001 -s /bin/false -d /bin/null -c "pureftpd user" -g ftpgroup ftpuser ! 
Log in E AE E E E ES S A A S E E E A E N E A E ET ; 
Create a new account 
Request new password 
4 Create The MySQL Database For PureFTPd 
Now we create a database called pureftpdand a MySQL user named pureftpdwhich the PureFTPd daemon 
Facebook will use later on to connect to the pureftpddatabase: 
ı mysql -u root -p 
‘| CREATE DATABASE pureftpd; 
ı GRANT SELECT, INSERT, UPDATE, DELETE, CREATE, DROP ON pureftpd.* TO 'pureftpd'@'localhost' 
' IDENTIFIED BY 'ftpdpass'; 
7 : ' GRANT SELECT, INSERT, UPDATE, DELETE, CREATE, DROP ON pureftpd.* TO 
Who's online | ‘pureftpd'@'localhost.localdomain' IDENTIFIED BY 'ftpdpass'; 
! FLUSH PRIVILEGES; 
There are currently 4 users E T TE T T A ETE E E NE N E T E E A E E E E. 
and 3526 guests online. , , , 
Replace the string ftpdpass with whatever password you want to use for the MySQL user pureftpd. Still on 
the MySQL shell, we create the database table we need (yes, there is only one table!): 
HowtoForge PAES ENEE SASAE ESEE 
Forums ' USE pureftpd; 
Mail Server DNS RELEASE NE OH DECAL LT ON NRE a OIE 
API and client ı CREATE TABLE ftpd ( 
template ' User varchar (16) NOT NULL default '', i 
, , ' status enum('0','1') NOT NULL default '0', 
Confi unn Debian ' Password varchar (64) NOT NULL default '', 
networking with | Uid Varchar (il) NOT NULL default '-1', i 
ISPCFG3 ! Gid varchar (11) NOT NULL default '-1', 
, A r (120) eNO) e a 7 ! 
Server-wide ' ULBandwidth smallint (5) NOT NULL default '0', ! 
Redirects ' DLBandwidth smallint (5) NOT NULL default '0', 
9 ; comment tinytext NOT NULL, i 
Protect 2 files? ı idpaccess varchar (15) NOT NULL default '*', i 
Where hawe all the e E smallint (5) NOT NULL default '0', 
packages gone? QuotaFiles int (11) NOT NULL default OF 
| PRIMARY KEY (User), 
Installation_error ' UNIQUE KEY User (User) 
APS ' ) TYPE=MyISAM; 
Dashboard not LAA SENDS EDAD ELLIE TENE ED ELE LELAND ANTE 
loading ISPConfig . 
3.5.4 | quit; 
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DNS-Zone Client 


Permissions As you may have noticed, with the quit; command we have left the MySQL shell and are back on the Linux 
Database error shell. 
after upgrade to 


3.0.5.4p1 BTW, (I'm assuming that the hostname of your ftp server system is serverl.example.com) you can access 
phpMyAdmin under http: //serverl.example.com/phpmyadmin/ (you can also use the IP address instead of 
serverl.example.com) in a browser and log in as the user pureftpd Then you can have a look at the 


News database. Later on you can use phpMyAdmin to administrate your PureFTPd server. 
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5 Configure PureFTPd 


Edit /etc/pure-ftpd/pure-ftpd.conf and make sure that the ChrootEveryone, MySQLConfigFile, and 
CreateHomeDir lines are enabled and look like this: 


ChrootEveryone yes 

ees 

MySQLConfigFile /etc/pure-ftpd/pureft 
eee 

CreateHomeDir yes 
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The ChrootEveryone setting will make PureFTPd chroot every virtual user in his home directory so he will not 


be able to browse directories and files outside his home directory. The CreateHomeDir line will make 
PureFTPd create a user's home directory when the user logs in and the home directory does not exist yet. 


moe Then we edit /etc/pure-ftpd/pureftpd-mysql.conf. It should look like this: 


' op /etc/pure-ftpd/pureftpd-mysql.conf /etc/pure-ftpd/pureftpd-mysql.conf_orig 
' cat /dev/null > /etc/pure-ftpd/pureftpd-mysq!l . conf 
' vi /etc/pure-ftpd/pureftpd-mysql .conf 
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Now we start PureFTPd: 
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